#### COMP 122/L Lecture 9

Mahdi Ebrahimi

Slides adapted from Dr. Kyle Dewey

#### Outline

- The compare (cmp) instruction
- Conditionally-executed instructions
- Translating simple if statements

# The compare (cmp) instruction

Subtracts two given operands, discarding the result. However, the status bits (e.g., carry, zero, etc.) get set.

#### Syntax

CMP Rn, Operand2

where:

Rn is the ARM register holding the first operand.

Operand2 is a flexible second operand.

#### Operation

These instructions compare the value in a register with Operand2. They update the condition flags on the result, but do not place the result in any register.

The CMP instruction subtracts the value of Operand2 from the value in Rn. This is the same as a SUBS instruction, except that the result is discarded.

## **ARM Flag Bits**

Subtracts two given operands, discarding the result. However, the status bits (e.g., carry, zero, etc.) get set.

- Condition Code Flags NZCV
  - N ("Negative flag")
    - $\Box$  0/1 = value is positive/negative
  - Z ("Zero flag")
    - 0/1 = result is non-zero/zero
  - C ("Carry flag")
    - 0/1 ="extends" for shift/"borrows" for subtraction
  - V ("Overflow flag")
    - $\Box$  0/1 = no overflow/overflow caused by last arithmetic operation

Subtracts two given operands, discarding the result. However, the status bits (e.g., carry, zero, etc.) get set.

> mov r0, #5 cmp r0, #5

Subtracts two given operands, discarding the result. However, the status bits (e.g., carry, zero, etc.) get set.

mov r0, #5
cmp r0, #5
Sets zero bit/flag
(result is zero)

Subtracts two given operands, discarding the result. However, the status bits (e.g., carry, zero, etc.) get set.

mov r0, #5
cmp r0, #5
Sets zero bit/flag
(result is zero)

mov r0, #5 cmp r0, #20

Subtracts two given operands, discarding the result. However, the status bits (e.g., carry, zero, etc.) get set.

mov r0, #5
cmp r0, #5
Sets zero bit/flag
(result is zero)

mov r0, #5
cmp r0, #20
Sets negative bit/flag
(result is negative)

Status bits say something about the result of arithmetic comparisons

Status bits say something about the result of arithmetic comparisons

mov r0, #5
cmp r0, #5
Sets zero bit/flag
(result is zero)

Status bits say something about the result of arithmetic comparisons

mov r0, #5 cmp r0, #5 Sets zero bit/flag (result is zero) Operands must have been equal.

Status bits say something about the result of arithmetic comparisons

mov r0, #5 cmp r0, #5 Sets zero bit/flag (result is zero) Operands must have been equal.

mov r0, #5
cmp r0, #20
Sets negative bit/flag
(result is negative)

Status bits say something about the result of arithmetic comparisons

mov r0, #5 cmp r0, #5 Sets zero bit/flag (result is zero) Operands must have been equal.

mov r0, #5 cmp r0, #20 Sets negative bit/flag (result is negative) First operand must be < second.

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**mi** r0, #42

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**mi** r0, #42

move if the negative bit is set

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**mi** r0, #42

move if the negative bit is set

mov**pl** r1, #23

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**mi** r0, #42

move if the negative bit is set

movpl r1, #23 move if the negative bit is not set

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**eq** r0, #42

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**eq** r0, #42

move if the zero bit is set

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**eq** r0, #42 move if the zero bit is set

mov**ne** r0, #42

ARM allows for instructions to be *conditionally* executed, depending on the values of the status bits.

mov**eq** r0, #42

move if the zero bit is set

movne r0, #42 move if the zero bit is not set

#### Basic data processing instructions

| MOV | Move a 32-bit value                                                                 | MOV Rd, n     | Rd = n                   |  |  |
|-----|-------------------------------------------------------------------------------------|---------------|--------------------------|--|--|
| MVN | Move negated (logical NOT) 32-bit value                                             | MVN Rd,n      | $Rd = \sim n$            |  |  |
| ADD | Add two 32-bit values                                                               | ADD Rd, Rn, n | Rd = Rn+n                |  |  |
| ADC | Add two 32-bit values and carry                                                     | ADC Rd, Rn, n | Rd = Rn+n+C              |  |  |
| SUB | Subtract two 32-bit values                                                          | SUB Rd, Rn, n | Rd = Rn-n                |  |  |
| SBC | Subtract with carry of two 32-bit values                                            | SBC Rd, Rn, n | Rd = Rn - n + C - 1      |  |  |
| RSB | Reverse subtract of two 32-bit values                                               | RSB Rd,Rn,n   | Rd = n-Rn                |  |  |
| RSC | Reverse subtract with carry of two 32-bit values                                    | RSC Rd,Rn,n   | Rd = n-Rn+C-1            |  |  |
| AND | Bitwise AND of two 32-bit values                                                    | AND Rd, Rn, n | Rd = Rn AND n            |  |  |
| ORR | Bitwise OR of two 32-bit values                                                     | ORR Rd, Rn, n | Rd = Rn OR n             |  |  |
| EOR | Exclusive OR of two 32-bit values                                                   | EOR Rd, Rn, n | Rd = Rn XOR n            |  |  |
| BIC | Bit clear. Every '1' in second operand clears<br>corresponding bit of first operand | BIC Rd,Rn,n   | Rd = Rn AND (NOT n)      |  |  |
| CMP | Compare                                                                             | CMP Rd,n      | Rd-n & change flags only |  |  |
| CMN | Compare Negative                                                                    | CMN Rd,n      | Rd+n & change flags only |  |  |
| TST | Test for a bit in a 32-bit value                                                    | TST Rd,n      | Rd AND n, change flags   |  |  |
| TEQ | Test for equality                                                                   | TEQ Rd, n     | Rd XOR n, change flags   |  |  |

| MUL | Multiply two 32-bit values | MUL Rd, Rm, Rs     | Rd = Rm*Rs        |
|-----|----------------------------|--------------------|-------------------|
| MLA | Multiple and accumulate    | MLA Rd, Rm, Rs, Rn | Rd = (Rm*Rs) + Rn |

#### Features of Conditional Execution instructions

Improves execution speed and offers high code density

Illustration:

| 'C' Program<br>fragment                       | ARM program using<br>branching instructions                                | ARM program using<br>conditional instructions                    |  |
|-----------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------|--|
| <pre>if (r0==0) {     r1=r1+1; } else {</pre> | CMP r0,#0<br>BNE else<br>ADD r1,r1,#1<br>B end<br>else ADD r2,r2,#1<br>end | CMP r0,#0<br>ADDEQ r1,r1,#1<br>ADDNE r2,r2,#1                    |  |
| r2=r2+1;<br>}                                 | Instructions - 5<br>Memory space - 20 bytes<br>No. of cycles - 5 or 6      | Instructions - 3<br>Memory space - 12 bytes<br>No. of cycles - 3 |  |

## **Example:** conditional execution.s

#### Translating simple if statements

#### Example I

• An example: if (r2 != 10) r5 = r5 + r2 - r3



#### Example 2

| if   | ((r1 == | r3) && (r5 | 5 == r6)) r7 | = r7 + | 10        |
|------|---------|------------|--------------|--------|-----------|
|      | CMP     | r1,r3      |              |        |           |
|      | BNE     | SKIP       |              | CMP    | r1,r3     |
|      | CMP     | r5,r6      |              | CMPEQ  | r5,r6     |
|      | BNE     | SKIP       | v            | ADDEQ  | r7,r7,#10 |
|      | ADD     | r7,r7,#10  |              |        |           |
| SKIP | • • •   |            |              |        |           |

#### **Translating** if

- Simple ifs can be translated with conditionally-executed instructions
- Example:
  - AbsoluteValue.java
  - absolute\_value.s